package 深信服;

import java.util.Scanner;

/**
 * @author tmh
 * @date 2024/8/23 16:35
 * @description
 */
public class 重复串查找 {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        while (in.hasNextLine()) { // 注意 while 处理多个 case
            String str = in.nextLine();
            int result = isRepeatedSubstring(str);
            System.out.println(result);
        }
    }

    public static int isRepeatedSubstring(String str) {
        int mid = str.length() / 2;

        for (int i = mid; i > 1; i--) {
            int count = 0;
            //如果走到了下一个循环，说明上一次循环没有找到满足条件的，所以count要重置为0
            for (int j = 0; j < str.length() - i; j++) {
                if (str.charAt(j) == str.charAt(i + j)) {
                    count++;
                } else {
                    count = 0;
                }
                if (count == i) {
                    return count * 2;
                }
            }
        }
        return 0;
    }
}
